import _ from 'lodash'; import type { GetStaticPropsContext, NextPage } from 'next'; import ReactMarkdown from 'react-markdown'; import Head from 'next/head'; import Emoji from '../Emoji'; import Image from '../Image'; import deepReadDir from '../deepReadDir'; import emojiPlugin from '../emojiPlugin'; import fs from 'fs'; import remarkGemoji from 'remark-gemoji'; const MARKDOWN_DIR = '../eug-vs-xyz/src'; const EMOJI_DIR = 'public/emoji'; const transformLinkURI = (uri: string): string => { return uri.match(/(.*)\.md/)?.[1] || uri; } export const getStaticProps = async (context: GetStaticPropsContext) => { const path = _.isArray(context.params?.path) && context.params?.path || [context.params?.path]; const markdownSource = fs.readFileSync(`${MARKDOWN_DIR}/${path?.join('/')}.md`).toString(); const emojiFileNames = fs.readdirSync(EMOJI_DIR); return { props: { markdownSource, emojiFileNames, path, } } } export const getStaticPaths = async () => { const globalPaths = await deepReadDir(MARKDOWN_DIR); const paths = globalPaths .map(globalPath => globalPath.match(`${MARKDOWN_DIR}/(.*)\.md`)?.[1] ) .filter(p => p) .map(p => p?.split('/')) .map(path => ({ params: { path } })); return { paths, fallback: 'blocking', } } const Page: NextPage = ({ markdownSource, emojiFileNames }: any) => { return ( <> {`Eugene's Space`}
{markdownSource}
); }; export default Page;